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6.t OVERVIEW 

The bus designated for I/O operations is called the F bus 
The F bus is a 36 bit bidirectional data bus , and in addition 
contains control and address signals as shown in Figure 6-1 
Three types of operations can occur on the F bus: ( IQT ) for 
Data transfers to and from the CPU, ( DMA ) for channeling data 
from a device directly to and from memory, and INTERRUPT for 
getting the CPU's attention. 





CM 

> 

J ' ' , ' 

> 


- =' 'x 




lOA 15:35 






^w ' 




ION 00:04 








lOB SUBSELECT 00:03 




^tJMt,^ ' 




lOD 00:35 








INT ADR 00:04 




^^ 




BUS ANY INT L 


aWH ^ 








BUS INT STB 


•■<^ 








I06 DRIVE IN 




< 




lOB OUT STB 










BUS RESET 










INT IT'S YOU OUT 






^^ 




SOME REQ L' 




y Conlrol sig 


<^ 




BUS REQUEST STB 


-«- 




^ 


DMA RD RQ 




> 


^ 


DMA WRT RQ 










DMA RD SECOND CY STB 






^ 




BUS DMA CY 






< 











Data 



[ F-BUS SIGNALS ] 

Figure 6-1 



6-1 



1st lOB OPERATION 



3rd lOB OPERATION 



1st CYCLE 



,2pd CYCLE 



;^^„„<;mi 



1st CYCLE 



2n„d„CYCL,^ 



IDB CYCL 



1st CYCLE 



^i^lH£k| 13, cYCLd 



2nd CYCLE 



1111^1— 



2nd lOB OPERATION 4th lOB OPERATION 

Figure 6-2 

[ lOT CYCLE OVERLAPPING ] 



Each type of lOB operation involves two machine cycles. 
However, by overlapping opposite cycles of contiguous lOB opera 
tions to the same device, each cycle may act as an lOB cycle. 
Figure 6-2 illustrates this further. 

As shown in Figure 6-2, the second cycle of each operation 
is referred to as an lOB cycle. It is during this cycle that 
data is actually transferred on the F bus. During the first 
cycle of the first operation the device code is latched for 
eternity into the ION BUF. Because of inherent restrictions on 
uCode field usage, setting up the device code requires a sepa- 
rate cycle, during the first operation. 

6.1 lOT TRANSFERS 

An lOT transfer originates after the CPU clocks a micro 
instruction with lOB REQ IN, or OUT coded in its SPEC RUN Field 
lOB REQ IN or OUT is decoded to set lOB DRIVE IN or lOB OUT at 
the first BUS CLK during the NEXT cycle. BUS CLK is a delayed 
version of CPU CLK, which determines the lOB cycles. Figure 
6-3 illustrates this timing. 
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[ lOT IN &■ OUT TIMING ] 
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6«2j lOT out operations 

Each CPU CLK addresses and decodes another micro 
Two or more micro instructions are required for any I 
shown in Figure 6-4. lOB OUT is decoded from the SPE 
of the first micro instruction as previously mentione 
micro instruction may also decode the EXT D field as 
This enables the Main Memory Data which may represent 
of E from the Macro I/O instruction into the lOD regi 
BUS, as a result of decoding an lis from the DEST f 
second micro instruction asserts the device subselect 
image of the MAP F field. Also this instruction must 
7g (constant) in its DEST field in order to load the DE 
register as an image of the Constant field. The CONS 
physically the low order bits of the MASK field, will 
physical device number only when the EXT D field is c 
It is important to realize that different micro instr 
be addressed from the macro op-codes, and that the op 
particular to the device code. Thus, for each type o 
instruction the microcode will be addressed in a mann 
the correct device address will be sent to the F BUS, 
execution of the second and subsequent micro instruct 
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The BUS CLK, that occurs 100 nS after the CPU CLK, which 
initiated the second cycle, will cause lOB OUT to set from lOB 
OUT RQ. lOB OUT causes the OUTPUT DATA BUFFER (lOD BUF) to be 
enabled onto the F BUS. At this point in time the F BUS has all 
the necessary information in terms of DATA, DEVICE ADDRESS, and 
SUBSELECT CODE to perform the lOT operation. 

The CPU CLK which signifies the end of the second machine 
cycle is ANDED with lOB OUT to produce lOB OUT STB. This signal 
is sent to the F BUS and strobes the addressed device to latch 
the SUBSELECT CODE, and the DATA into its internal registers. 
The SUBSELECT CODE, specifies what type of DATA was sent, and is 
interpreted by the device as a command. The second micro instruc- 
tion may involve yet another lOT operation on the next cycle by 
setting the appropriate code for lOT OUT or lOT IN, in the SPEC 
field. The device code which is still latched and on the F BUS 
allows any subsequent lOT operations to use only the format of 
the second micro instruction thus permitting eyery MACHINE CYCLE 
to be an lOB CYCLE. The last cycle to be performed does not set 
lOT IN or OUT in its SPEC field, hence terminating the REQUEST for 
subsequent lOB operations. 

lOT type transfers are NOT used to transfer DATA to and 
from MASS STORAGE DEVICES, but instead their DATA field is inter- 
rupted as CONTROL DATA by a controller. Actual mass storage 
DATA transfers are done directly to memory by DMA operations. In 
this case, the CPU must specify to the controller a starting ad- 
dress in main memory, and a location address of where the DATA 
can be found on mass storage. It is the purpose of lOT transfers 
to provide this type of information. 

Since there is no handshake involved in an lOT OUT, an 
operation to a non-existent device does not cause the F BUS to 
hang, nor will the CPU ever know whether the device received the 
information without doing an lOT IN. (Setting Interrupts are 
an obvious exception to this). 



6.2.2 iOT in operations 

Inputting control information from an F BUS controller, 
shares much of the same timing and features as IOT OUT, with 
major differences occurring in the destination of DATA, and 
some of the microcode fields. As with an IOT OUT this type of 
operation is not used for obtaining actual DATA from MASS STORAGE, 
but rather is used for inquiring about the status of a controller 
by the CPU. 

A macro I/O input instruction will cause the execution 
of two or more micro instructions. At the end of the second micro 
instruction the requested information in terms of a 36 bit DATA 
word will be available in the CPU. Destinations for input data 
may be either a location in main memory, or an accumulator in 
the CPU as determined by the effective address of the MACRO I/O 
Input instruction. 
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[ lOT IN OPERATION ] 
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When the first micro instruction is addressed (referring to 
Figure 6-^), it will have coded in its SPEC RUN field an octal 
16 (lOD liN). This will allow the signal lOB DRIVE IN to set 
during the second cycle. Also in the first micro instruction 
period we must load the DEVICE ADDRESS register since the field 
which does this also specifies the code for gating the input 
DATA which must be done during the second cycle. This is done 
with the DEST field = 73, and the EXT D field = 3^ The EXT D 
field code 3q specifies that the constant field will contain 
the correct DEVICE CODE to be loaded into the DEVICE ADDRESS 
register, and a DEST field of 73 causes the contents of the con- 
stant field to be strobed into the ION BUF or Device Address 
Register. 

The first micro instruction, having specified the type of 
operation (lOB IN), and the device number, as well as setting 
up lOB REQ IN, leaves the second micro instruction with the task 
of specifying the SUBSELECT CODE, gating the appropriate DATA 
into the CPU and writing it into main memory. The SUBSELECT 
field is taken from the MAP F field of the micro code as a direct 
image. This field will be coded accordingly in the second micro 
instruction to specify the source of the input data from within 
the controller on the F BUS. The second micro instruction will 
also have its EXT D field = 63. The purpose of this field is to 
specify the source of the external DATA mixer located in the CPU 
to be selected as lOD, or in other words, the F BUS DATA lines. 
The second instruction will also have its DEST FIELD = 1 (MEMSTO). 
The F BUS DATA will be enabled through the E)(TFRNAL_DATA SELECTOR 
through the ROTATOR, the MASKER , the ALU , and onto" the :0' BUS 
where it will be clocked into the HOLD REGISTER and during the 
next machine cycle sent to a main memory location specified in the 
E of the MACRO INSTRUCTION which originated the operation. An 
important point to remember is that the last micro instruction of 
the I/O routine must strobe the ION BUF by DEST = 7q with the 
EXT D field = 3g and CONSTANT = 0. This will zero the F BUS ION 
lines which were set during the first micro instruction. 

6.3 DMA TRANSFERS 

DMA provides the means, by which I/O devices on the F BUS 
may transfer mass storage data to and from MAIN MEMORY. All 
DMA transfers are initiated by F BUS devices and are arbitrated 
in terms of priority in the event that more than one device asserts 
a DMA request at the same time. 

MAIN MEMORY PHYSICAL ADDRESSES are supplied by, and are 
incremented by the device for each word which is sent or^ 
received. Figure 6-6 shows data and address paths in simpli- 
fied form. Note data and address information utilize regis- 
ters within the CPU. The reason for this type of architecture 
is that the MAIN MEMORY is not mul ti -control! ed , and can thus 
handle only one device;the CPU. 

DMA operations are handled in a totally autonomous manner 
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FIGURE 6-6 

[ SIMPLIFIED DATA AND ADD'RESS 
PATHS FOR DMA OPERATIONS ] 
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Another condition which will cause DMA onerations to be 
temporarily suspended is when the CPU does an. IDT operation. 
In this case any DMA requests will yield the F Bus to the 
CPU for the duration of the lOT while the req^uesl: for DMA 
remains pending, to be acknowledged upon completion of the 
lOT. 
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only effect this has on any number crunching which the uCode 
may be involved in at the time of the DMA is to allow more time 
than what otherwise may be required for propagation allowances 
relative to any operation invoked by the uCode. 

6.3.1 DMA priority 

In the event that more than one F BUS device makes a DMA 
request, a determination must be made based on each device's 
priority assignment as to whose request to honor first. This 
priority is determined soley by the particular F BUS slot 
into which devices are plugged. Figure 6-7 illustrates how this 
convention is implemented. A device will set its INTERNAL 
REQUEST when it is ready to read or write data. 

OTHER F BUS DEVICES — 
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[F BUS Priority Arbitration] 
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Figure 6-7 

BUS REQUEST STROBE clocks a flop which sets SOME RQ when INTERNAL 
REQUEST is true. BUS RQ STB will occur every CPU CLK, unless 
SOME RQ already has been set. Therefore the BUS RQ STB which causes 
SOME RQ to set will inhibit further BUS RQ STROBES. At this 
point the first physical device on the bus with its SOME RQ 
flop set will become F BUS MASTER by virtue of the daisy chained 
signal named IT'S YOU. This signal is actually floating going 
into the first physical device slot which in Figure 6-7 is 
device A. Thereafter, provided that device A does not have its 
SOME RQ flop set it will be gated on down the F BUS to device 
B etc. 
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6.3.2 DMA write 

DMA write operations are initiated by an F BUS device 
whenever it has data to deposit into MAIN MEMORY, As a typical 
example the CPU under program control will issue several commands 
to the device in th^^ form of lOT transfers. The commands will 
specify the location on mass storage of a block" of data, the 
initial address in main memory, and that it is to be a DMA WRITE. 
Once these commands have been issued the CPJ is free to go about 
other business, meanwhile the F BUS device (normally a periphial 
controller) will command the specific periphial to locate the 
beginning of the deisired data block and begin reading it into 
a FIFO buffer. Once the F BUS device has data ready to be 
sent to main memory it will raise its internal request and 
will begin arbitration according to priority as previously 
discussed. Assuming that n.o other requests are pending from 
other F BUS devices or that the particular device being dis- 
cussed is the highest priority; it will then become 
F BUS MASTER. Refer to Figures 6-8 arid 6-9 and observe that 
once F BUS MASTER, the device will drive the initial memory 
addressj havi ng been previously loaded into a register by an lOT 
OUT transfer, onto lOA lines 15:35. The address will be qated 
onto the PHYSICAL MEMORY ADDRESS lines (PADR) between the 
occurance of CPU CLK and BUS CLK. If the CPU was attempting 
a memory request or an lOT the DMA cycle will remain pending 
for one or more cycles, and the above operation and subsequent 
operations will be delayed accordingly. With the occurance of 
BUS CLK the memory cycle will begin and DATA will be transmitted 
from the F BUS device onto the F BUS lOD lines 00:35 and the 
CPU will gate the lOD lines onto the MEMORY OUT lines for 
storage. The next cycle will once again be available for a 
DMA cycle and the same process repeats itself. 

6.3.3 DMA read 

While it was possible to perform a DMA WRITE operation in 
only one machine cyle a DMA READ will requrire two machine cycles 
During the first cycle the device supplies a main memory address 
to the CPU and the CPU uses this address to retrieve the DATA 
from memory and latch it internally. The second cycle will 
send the data onto the device. The major reason that two 
cycles are necessary comes from the fact that DATA is 
received by the CPU from MEMORY too late In the machine cycle 
to be sent onto the Controller on the F BUS, and hence another 
cycle is required for this task. 

During the first cycle of a DMA. READ a great deal of simi- 
larity exists with the exception that a MEMORY READ will be done 
Priority arbitration remains unchanged, and provided that the 
CPU desires neither a MEMORY RQ or an lOT transfer the cycle 
of events will continue. Otherwise the DMA operation will be 
delayed until this condition is "satisfied, whereby the DMA 
OPERATION will continue. 
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[DMA WRITE CYCLE TIMING DIAGRAM] 



If the CPU sees that it is doing a DMA READ it will 
drop DMA CYCLE after the first cycle and bring up DMA SECOND 
CYCLE. With DMA SECOND CYCLE = 1 , the next CPU CLK will cause 
DMA SECOND CYCLE STROBE whose purpose is to latch the DATA 
intoF BUS device from the lOD lines. Both figure 6-10 and 
6-11 show timing and flow of events in detail for DMA READ 
operati ons . 

6,4 INTERRUPTS 

Interrupts provide the means by which I/O devices may 
alert the CPU to various conditions which exist from within 
the device. These conditions may include errors, and completion 
of data transfers. For purposes of understanding the hardware 
involved with priority interrupts we shall segregate the logic 
into two subjects; that of arbitrating a request, and that of 
"servicing and dismissing the request. 
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Figure 6-11 



The arbitration process will allow a priority scheme to 
determine which device will get the processors attention first 
in the event that more than one device makes a request at the 
same time. However once the processor honors a particular request, 
other requests are locked out (even if they are from a higher priority 
device). In other words further arbitration is inhibited until 
the dismissal of the interrupt being serviced. For this reason 
most interrupt service routines are kept shorter than 30 or 40 
micro-seconds. 
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Servicing interrupts is controlled by the micro code. 
During a dispatch where by the micro code is going to branch 
to service the next instruction in the macro instruction sequence, 
the interrupt flop is tested and if found to be set the microcode 
will instead dispatch to a special location to begin handling 
the request. Upon completion of the service, or handler routine 
the microcode wi 1 do yet another dispatch, at which time if there 
are no additional interrupts the dispatch will branch the microcode 
according to the op-code of the instruction previously being 
considered. It is important to be aware that dispatching occurs 
preceding the execution of each macro instruction. 



6.4.1 Interrupt arbitration 



Should more than one device request an interrupt at the 
same time it will be necessary to assign a priority such that 
faster devices such as disk will be reconized before slower ones 
like mag-tape. The convention used for this purpose is almost 
identical to that which was incorporated into the DMA priority 
scheme, however the hardware for doing PI arbitration is completly 
seperate. 



The signal BUS INT STB is sent out on the F BUS as an 
image of CPU CLK. This is a bussed signal which is used to 
synchronize the internal requests of different devices. Before 
a device may become the F BUS MASTER it must also have INT IT'S 
YOU OUT as a true condition. INT YOU OUT is a daisy chained 
signal, which establishes the priority of a particular device 
according to the physical F BUS slot into which it is plugged. 
This signal is actually floting as it enters the first device 
slot on the F.BUS This allows the device plugged into that 
slot to always become F BUS MASTER if its INTERNAL REQUEST 
is set when it receives a BUS INT STB. 
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Figure 6-13 

[ SIMPLIFIED INTERRUPT TIMING ] 
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6.4.2 Interrupt service 

During each sequencial macro instruction, the 
micro-code will perform a conditional dispatch. This 
dispatch in its normal form, will branch the micro-code 
as a function of the op-code of the macro instruction 
contained in the IR (instruction register). However, 
if when the dispatch occurs, the INT flop is set the 
micro code will instead be forced to location 2002. 



After the arbitration process is completed the 
selected interrupring device will place its device 
address on to the INR ADR lines (00:04). This device 
address will be latched onto the DEV ADR lines (00:04), 
and will also address a block of 8 locations in A-MEM. 
The A-MEM contains 256 locations x 36 bits, and accordingly 
requires 8 bits of address. Of these 8 bits the high 
order 5 bits are derived directly from INT ADR (00:04) 
and are used to address one of 32 blocks. The remaining 
three low order address bits of the A-MEM are supplied 
from one of two fields within the micro instruction 
depending on whether data is being read from or written 
into the A-MEM it need only be concerned with selecting 
which word it wishes to reference. 



As mentioned earlier the micro-code checks the 
interrupt flop during each macro instruction dispatch 
and if the interrupt condition is satisified the micro- 
code will be forced to location 2002. Once at this location 
the micro -code "still doesn't know" which device has caused 
the interrupt. In order that this be resolved the micro- 
code will do a SPECIAL DISPATCH (S DISP), unconditionally, 
vectoring from word of the A-MEM block currently add- 
ressed by the interrupting device. The S DISP function 
is specified by a J CODE = (15)g and causes the next 
micro-code address to be loaded from the BUS. In the 
instruction at 2002 we will also specify a function for 
getting word onto the BUS. This Is accomplished by 
utilization of the 4 bit EXT D field whose nigh oraer bit 
being = 1 specifies the A-MEM as the selected source of 
EXTERNAL DATA SOURCE MIXER whose output feeds the BUS 
via the ALU, the MASK, and the ROTATOR. The remaining 
low order 3 bits of the EXT D field are used to provide 
the three low order address bits to the A-MEM and thus 
select the word. Since word is being used in the 
S DISP, the EXT D field = 10). See figure 6-14. 
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[ SIMPLIFIED INTERRUPT DISPATCHING ] 
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A simplified illustration of the micro-code and 
hardware implemented in performing an lOT OUT from A-MEM 
is shown in figure 6-15. This type of lOT is simpler 
than one from main memory in that we need not specify 
the device address. The SPEC field = (17) will cause 
an lOT OUT on the next machine cycle, while the EXT D 
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and DEST fields will select the A-MEM word and route 
the Data through the EXTERNAL DATA SOURCE onto the 
BUS and strobe the lOD BUF to latch the data from the 
BUS. The EXT D field selects the appropriate A-MEM 
word according to the three low order bits, while the 
high order bit causes the A-MEM to be selected as the 
input to the EXTERNAL DATA SOURCE. By setting the DEST 
field = (11) the lOD BUF will be strobed thus latching 
the data. 



In a single lOT out the second micro instruction 
need only specify the device subselect code as an image 
of the MAP field. In the event that successive lOT outs 
are to be performed they may be over lapped by keeping 
the SPEC field = (17). 



Figure 6-16 shows the lOT IN operation to A-MEM. 
lOT IN operations may not be over lapped, This is 
because the SPEC field must be used during the second 
micro instruction to write enable the A-MEM. Another 
apparent difference occurs in the A-MEM address which 
is derived from the low order 3 bits of the DEST field 
(all other bits in the DEST FIELD MUST BE ZERO). 



6-19 



SPEC 



EXT D 



DEST 



1st micro instr 



lOB OUT STB 




DATA 

A-MEM 

36x256 . 



^ SPEC '^ MAP F 
(17)?^ ISUBSELECTT 



(NOTE A): 
2nd micro instr 



NOTE A: SPEC FIELD is used 
only if overlapped., successive 
lOT OUT transfers are to be 
used. SPEC=17 causes lOT 
OUT on NEXT cycle. EXT and 
DEST must also be respecified 
(NOT SHOWN). 



Figure 6-15 

[lOT OUT DATA FROM A-MEMORY] 
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[lOT IN TO A-MEMORY] 
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